// 这是路由处理函数模块

// 导入数据库操作模块
const db = require('../db/index')

// 获取文章分类列表的处理函数
exports.getArtCates = (req, res) => {
    // 定义查询分类列表数据的 SQL 语句
    const sql = `select * from ev_article_cate where is_delete=0 order by id asc`
    // 调用 db.query() 执行 SQL 语句
    db.query(sql, (err, results) => {
      if (err) return res.cc(err)
      res.send({
        status: 0,
        message: '获取文章分类数据成功！',
        data: results,
      })
    })
  }

// 新增文章分类列表的处理函数
exports.addArticleCates = (req, res) => {
    // 1. 定义查重的 SQL 语句
    const sql = `select * from ev_article_cate where name=? or alias=?`
    // 2. 执行查重的 SQL 语句
    db.query(sql, [req.body.name, req.body.alias], (err, results) => {
      // 3. 判断是否执行 SQL 语句失败
      if (err) return res.cc(err)

        // 分类名称 和 分类别名 都别占用
        // 4.1 判断数据的 length
        if (results.length === 2) return res.cc('分类名称与分类别名被占用，请更换后重试！')
        // 4.2 length 等于 1 的三种情况
        if (results.length === 1 && results[0].name === req.body.name && results[0].alias === req.body.alias) return res.cc('分类名称与分类别名被占用，请更换后重试！')
        if (results.length === 1 && results[0].name === req.body.name) return res.cc('分类名称被占用，请更换后重试！')
        if (results.length === 1 && results[0].alias === req.body.alias) return res.cc('分类别名被占用，请更换后重试！')

        // 分类名称与别名未被占用
        // 新增文章分类的 SQL 语句
        const sql = `insert into ev_article_cate set ?`
        // 调用db.query() 执行新增文章分类的 SQL 语句
        db.query(sql, req.body, (err, results) => {
            // SQL 语句执行失败
            if(err) return res.cc(err)

            // SQL 语句执行成功，但是影响行数不等于 1
            if(results.affectedRows !== 1) return res.cc('新增文章分类失败！')

            // 新增文章分类成功
            res.cc('新增文章分类成功！', 0)
        })
    })
}

// 删除文章分类的处理函数
exports.deleteCateById = (req, res) => {
  // 定义标记删除的 SQL 语句
  const sql = `update ev_article_cate set is_delete=1 where id=?`
  // 调用 db.query() 执行 SQL 语句
  db.query(sql, req.params.id, (err, results) => {
    if (err) return res.cc(err)
    if (results.affectedRows !== 1) return res.cc('删除文章分类失败！')
    res.cc('删除文章分类成功！', 0)
  })
}

// 根据 ID 获取文章分类的处理函数
exports.getArtCatesById = (req,res) => {
  // 待执行的 SQL 语句
  const sql = `select * from ev_article_cate where id=?`

  db.query(sql, req.params.id, (err, results) => {
    // 执行 SQL 失败
    if(err) return res.cc(err)
    // SQL 语句执行成功，但是没有查到任何数据
    if(results.length !== 1) return res.send('获取文章分类失败！')

    // 成功，把数据返回给客户端
    res.send({
      status: 0,
      message: '获取文章分类成功',
      data: results[0]
    })

  })
}

// 根据 ID 更新文章分类的处理函数
exports.updateCateById = (req,res) => {
  // 定义查询 分类名称 和 分类别名 是否被占用的 SQL 语句
  const sql = `select * from ev_article_cate where id<>? and (name=? or alias=?)`
  // 执行查重操作
  db.query(sql, [req.body.id, req.body.name, req.body.alias], (err, results) => {
    // 执行 SQL 语句失败
    if(err) return res.cc(err)
    // 分类名称 和 分类别名 都是被占用
    if (results.length === 2) return res.cc('分类名称与分类别名被占用，请更换后重试！')
    if (results.length === 1 && results[0].name === req.body.name && results[0].alias === req.body.alias) return res.cc('分类名称与分类别名均被占用，请更换后重试！')
    // 分类名称 和 分类别名 分别被占用
    if (results.length === 1 && results[0].name === req.body.name) return res.cc('分类名称被占用，请更换后重试！')
    if (results.length === 1 && results[0].alias === req.body.alias) return res.cc('分类别名被占用，请更换后重试！')

    // 更新文章分类
    // 更新文章分类的 SQL 语句
    const sql = `update ev_article_cate set ? where id=?`
    // 执行更新文章分类的 SQL 语句
    db.query(sql, [req.body , req.body.id], (err, results) => {
      // 执行 SQL 语句失败
      if(err) return res.cc(err)

      // SQL 语句执行成功，但是影响行数为1
      if(results.affectedRows !== 1) return res.cc('更新文章分类！')

      res.cc('更新文章分类成功！')
    })
  })
}